import java.util.HashMap;
import java.util.Map;

class Solution {
    public int totalFruit(int[] fruits) {
        int left = 0;
        int right = 0;
        int len = 0;
        Map<Integer, Integer> map = new HashMap<>();
        while(right < fruits.length){
            //进窗口
            int value = map.getOrDefault(fruits[right], 0);
            map.put(fruits[right], value + 1);
            //出窗口
            while(map.size() > 2){
                int key = fruits[left];
                int val = map.get(fruits[left]);
                if(val > 1){
                    map.put(key, val - 1);
                }else{
                    map.remove(key);
                }
                left++;
            }
            //更新结果
            if(len < right - left + 1){
                len = right - left + 1;
            }
            right++;
        }
        return len;
    }
}